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HOW TO GET YOUR CPU 86/87 UP AND RUNNING IN UNDER 5 MINUTES, 

WITHOUT READING THE MANUAL 



This section is for those of you who are running this CPU board in 
a standard single user CompuPro configuration and do not intend to 
deviate from that standard configuration. You should be able to 
set the switches and jumpers as shown below and never have to 
change them again (unless you change your system configuration). 

If you want to know all the details about what these switches and 
jumpers do, you will have to read the rest of this manual. 



SWITCH SETTIHGS 

DIP SWITCH SI - Turn all paddles of dip switch SI OFF . 

DIP SWITCH S2 - Turn all paddles of dip switch S2 OFF . 

DIP SWITCH S3 - Turn paddles 1,5,6 and 8 of dip switch S3 OFF . 

Turn paddles 2,3,4 and 7 of dip switch S3 ON. 

DIP SWITCH S4 - Turn paddles 1 and 2 of dip switch S4 OFF . 

Turn paddles 3 through 10 of dip switch S4 ON . 

DIP SWITCH S5 - Turn all paddles of dip switch S5 OFF. 



JUMPERS 

Make sure there is a shorting plug installed at jumper location J8. 
J8 is located near the top left-hand corner of the board. There 
should be no shorting plugs installed at jumper locations JO 
through J7, which are located near the bottom left hand corner of 
the board. 



SWITCH SETTIHGS FOR OTHER COMPUPRO BOARDS 

Follow the switch settings as outlined in the software manual, with 
the following exception: If you have an "F" revision DISK 1 
(denoted by the part number 171F) or later, or a DISK 1A, consult 
the manual for how to get the 86 only boot. Move the shorting plug 
at jumper location J17 from the "A" position (which is the way it 
was probably shipped from the factory) to the "B" position. J17 is 
located just to the right of the EPROM. 

If you have an "E" revision DISK 1 (denoted by the part number 
171_E) or earlier, contact the dealer where you purchased the CPU 
86/87 for an upgrade EPROM that contains the 8086 boot code. 

If you are using MP/M 8-16 with your CPU 86/87, make sure you 
change the SYSTEM SUPPORT 1 board as follows. (These instructions 
are also included in your MP/M 8-16 documentation.) 



1) Carefully pull IC U28 from its socket. (IC U28 is located 
on the right hand side of the board.) 

2) Bend out pin 4 so that when the IC is replaced, pin 4 will 
not make contact with the socket or anything else. 

3) Replace IC U28 back in its socket and verify that every pin 
except pin 4 is back in its hole. 

Bring up a CP/M system and put a copy of your MP/M 8-16 disk in the 
B drive. Use the MPMGEN command as follows: 

A >B:MPMGEN B:MPMLDRFY.86 

copysys Version x.x 

Destination Drive name (or return to terminate) :B 

Function complete. 

Destination Drive name (or return to terminate) :<cr> 

A> 

Your MP/M 8-16 disk will now have a loader for the CPU86/87. You 
may proceed with the rest of the manual. 

NOTE: If you are going to use the CPU 86/87 board, you will not be 
able to run any 8 bit software. Therefore, the file "SWI.CMD" 
should be removed from your system disk. 



BOOTING UP THE SYSTEM 

If all the switches and jumpers in the system are set correctly 
(make sure your drives are jumpered per the DISK 1 manual if they 
are other than CompuPro drives), you should be ready to boot up the 
system. Make sure that all the boards are plugged squarely into 
the motherboard, replace the mainframe's cover, and turn on the 
power to the computer, terminal and disk drives. The light on your 
"A" drive should be flashing about twice per second. If it is not 
flashing, stop! Read the DISK 1 manual's troubleshooting section 
and correct the problem before proceeding. If the light is 
flashing, insert the CP/M or MP/M Disk #2 diskette into the A drive 
and close the drive door. CP/M-86 or MP/M 86 should sign on. CP/M- 
86 and MP/M 8-16 Disk #1 will not boot with the CPU 86/87. 



TECHNICAL MANUAL 



ABOUT THE CPU 86/87 



The CPU 86/87 from CompuPro is one of the most advanced 16 bit 
processors available for the IEEE 696/S-100 Bus. Based on Intel's 
high performance 8086 16 bit processor, it also includes sockets 
for the 8087 high speed math co-processor and 80130 Operating 
System Firmware component. Through a special arrangement with 
Intel, CompuPro has supplied this board with a "ROM-less" version 
of the 80130 so that the user may retain full use of that part's 
interrupt and timer capabilities without paying for software that 
may not be needed. The CPU 86/87 has been designed to accept the 
ROM part, in case you desire that feature. 

The CPU 86/87 includes circuitry that allows it to handle 8 and 16 
bit memory and I/O devices that conform to the IEEE 696/S-100 
protocol for 8 and 16 bit transfers. Both 8 and 16 bit types may 
be mixed in a system, the CPU 86/87 will dynamically adjust itself 
to the proper bus width. The CPU 86/87 is fully compatible with 
DMA devices that adhere to the IEEE 696/S-100 standard protocols 
(like the DISK 1A, DISK 2, DISK3 etc.). 

The CPU 86/87 currently operates at 8 and 10 MHz clock speeds, but 
was designed to accommodate faster clocks as faster CPUs are 
introduced. 

A special clock switching circuit allows the use of specially 
designed slave processors to share the bus with the CPU 86/87. Use 
of an 8 bit slave CPU would provide equivalent operation to our CPU 
8085/88 dual processor board, thus providing a simple way to 
execute libraries of existing 8 bit software, as well as CompuPro's 
exclusive MP/M 8-16. 

The CPU 86/87 includes power-on-jump capabilities that allow it to 
begin program execution on any 4K boundary in the lower 1 megabyte 
of address space. 

When you couple high speed operation with the power of the 
8086/8087 pair, the CPU 86/87 is truly a processor board for 
advanced computing systems of the eighties. Thank you for choosing 
a CompuPro product. 



SWITCH SETTINGS AND OPTION SELECTION 

This section gives you a detailed description of all the switch and 
jumper settings for the CPU 86/87. To set the board up for use in a 
standard CompuPro system configuration, refer to your CompuPro 
"CP/M-86 Technical Manual and Installation Procedures". 
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DIP SWITCH SI 

Use dip switch SI to select the memory address for the ROM internal 
to the 80130 chip. Since this board is supplied with a "ROM-less" 
part, the setting of these switches is unimportant until you want 
to use an 80130 with some code in it. The ROM space occupies 16K 
bytes and the CPU 86/87 allows it to reside on any 16K boundary in 
the 16 megabyte address space available on the IEEE 696/S-100 bus. 
Select the address with dip switch SI as follows: 

Paddle # Address Bit 

1 A23 

2 A22 

3 A21 

4 A20 ON = "0 

5 A19 

6 A18 

7 A17 OFF = "1 

8 A16 

9 A15 

10 A14 

To minimize power dissipation, turn all these paddles OFF . Note: 
There is also a master memory enable switch (paddle 1 of dip switch 
S3) which should be turned OFF to keep this address from 
interfering with system memory. 



DIP SWITCH S2 (and part of S4) 

Use all the paddles of dip switch S2 and two of the paddles from 
dip switch S4 to select the I/O address where the 80130 component 
resides. The 80130 I/O registers occupy a block of 16 port 
addresses out of the possible 65,536 1/0 port locations that the 
8086 can address. The CPU 86/87 allows the part to be addressed to 
any 16 port boundary in the 65,536 port locations addressable. Set 
this address with dip switch S2 and part of dip switch S4 as 
follows: 

S4 Paddle # Address Bit 

1 A15 

2 A14 

S2 Paddle # 

1 A13 

2 A12 

3 All ON = "0" 

4 A10 

5 A9 OFF = "1" 

6 A8 

7 A7 

8 ...... . A6 

9 A5 

10 A4 



The standard port address for this part is FFFO-F hex. To set the 
standard port address, turn all paddles of S2 and paddles 1 and 2 
of S4 OFF, Note: There is a master I/O enable switch for this part 
(paddle 2 of S3) and this should be set accordingly. 



DIP SWITCH S3 

Use dip switch S3 to select some of the various options on the CPU 
86/87 board. The individual paddle's functions are: 

Paddle 1 - Memory Enable: When this paddle is turned 0N } the 
16K byte memory space (selected by dip switch SI) used by 
the 80130 is enabled. When this paddle is turned OFF , the 
memory space is disabled. Since this board is supplied 
with a "ROM-less" version of the 80130, leave this paddle 
OFF . 

Paddle 2 - I/O Enable: When this paddle is turned ON, the 16 
byte I/O address space (selected by dip switches S2 and 
S4) used by the 80130 is enabled. When this paddle is 
turned OFF , the I/O address space is disabled. Currently 
any interrupt driven CompuPro software uses the system 
support board to arbitrate interrupts. Thus, this paddle 
should be turned ON so that the operating system will 
program the 80130 into a repressed and passive state. 

Paddle 3 - Wait State Enable: When this paddle is turned ON , 
the on-board wait state generator is enabled. One wait 
state will be inserted into every I/O cycle, or every 
memory and I/O cycle, depending on the setting of paddle 4 
(I/O Wait Only Enable). When this paddle is turned OFF , 
no on-board wait states will be generated. Note: Turning 
this paddle on or off during program execution may cause a 
program crash. 

Paddle 4 - I/O Wait Only Enable: When this paddle is turned ON 
in conjunction with paddle 3 (Wait State Enable) ON , one 
wait state will be inserted into every I/O cycle. When 
this paddle is turned OFF in conjunction with paddle 3 
(Wait State Enable) ON , one wait state will be inserted 
into every CPU cycle, memory and I/O. If paddle 3 (Wait 
State Enable) is OFF , paddle 4 will have no effect, (no 
wait states will be generated). Note: Turning this paddle 
on or off during program execution may cause a program 
crash. 

It is recommended that paddles 3 and 4 both be turned ON to cause a 
wait state to be inserted into every I/O cycle. This will minimize 
problems with slow I/O boards. After system operation is verified, 
paddle 3 may be turned off, but if the system then becomes "flaky", 
turn paddle 3 on again. Note that running the system with I/O wait 
states usually will not measurably degrade the system's perfor- 
mance . 



Paddles 5 and 6 - Unused. These paddles are not used and 
should be turned OFF. 

Paddle 7 - MWRT Enable: When this paddle is turned ON it 
enables the S-100 bus signal MWRT to be generated by the 
CPU 86/87. When this paddle is turned OFF , the MWRT 
signal is not generated by the CPU 86/87. The MWRT signal 
should then be generated elsewhere in the system. In a 
normal CompuPro single user system configuration, this 
paddle should be turned ON. 

Paddle 8 - <JDSB* Enable: When this paddle is turned ON, it 
allows the master bus clock (d) to be disabled by a 
temporary bus master asserting the c^DSB* signal on bus 
line 21. When this paddle is turned OFF, this feature is 
disabled. This new S-100 bus line has been defined by 
CompuPro for use with our slave processor boards or 
special DMA peripherals. For now, leave this paddle OFF. 
The manual supplied with a board that utilizes this line 
will instruct you to turn on the paddle. For a descrip- 
tion of how the d>DSB* line is implemented, see the Theory 
Of Operation Section of this manual. 



DIP SWITCH S4 

Use paddles 1 and 2 of this dip switch (in conjunction with dip 
switch S2) to select the I/O address of the 80130. For a 
description of paddles 1 and 2, see the section on dip switch S2 
above. 

Use the remaining paddles to select the I/O port address for the 
memory manager. -The lower byte of the port address is "hard-wired" 
to FD hex, but the upper byte is selectable by this dip switch as 
shown below: 

Paddle # Address Bit 

3 A15 

4 A14 

5 A13 ON = "0" 

6 A12 

7 All 

8 A10 OFF = "1" 

9 A9 

10 A8 



The CompuPro standard port address for the memory manager is 00FD 
hex. To set dip switch S4 for this standard address, turn paddles 
3 through 10 ON. 

For a description of what the memory manager does, see the "Using 
the Memory Manager" section of this manual. 



DIP SWITCH S5 

Use dip switch S5 to select the power-on-jump/jump-on-reset options 
of the CPU 86/87. Select the address where the 8086 will jump to 
at power-on and reset with paddles 1 through 8. Paddle 9 selects 
whether the 8086 does a jump at power-on only, or with every RESET 
in addition to power-on. Paddle 10 enables or disables the power- 
on- jump feature. 

The 8086 normally begins execution at address 0FFFF0 hex, but the 
power-on-jump feature allows execution to begin at any 4K address 
boundary in the lower 1 megabyte of address space by "jamming" a 
long jump instruction into the processor. Select the address with 
paddles 1 through 8 of dip switch S5 as shown below: 

Paddle # Address Bit 

1 A19 

2 A18 

3 A17 ON = "0" 

4 A16 

5 A15 

6 A14 OFF = "1" 

7 A13 

8 A12 

Paddle 9 - Jump-On-Reset Enable: When this paddle is turned ON in 
conjunction with paddle 10 (Power-On-Jump Enable) ON , the 
power-on-jump sequence is executed at power-on and every time 
a RESET occurs on the bus (usually caused by pushing the RESET 
button). When this paddle is turned OFF in conjunction with 
paddle 10 (Power-On-Jump Enable) ON , the power-on-jump 
sequence will only be executed at power-on. A RESET occurring 
on the bus will cause the normal 8086 reset operation 
(execution at 0FFFF0 hex) to occur. If paddle 10 (Power-On- 
Jump Enable) is turned OFF , the setting of paddle 9 will have 
no effect. 

Paddle 10 - Power-On- Jump Enable: When this paddle is turned ON , 
the power-on-jump circuitry is enabled. When this paddle is 
turned OFF , the power-on-jump circuitry will be disabled and a 
normal 8086 reset sequence will occur. 

The standard CompuPro system configuration does not require the use 
of the power-on-jump feature of the CPU 86/87, so all paddles of 
dip switch S5 should be turned OFF if this board is being used in 
the standard configuration. 



JUMPERS 

Jumpers JO through J7 are located near the lower left-hand corner 
of the board and are used to select the various interrupt configur- 
ations possible with the CPU 86/87. They are arranged as shown in 
the diagram following: 



Left-hand Side Right-hand Side 

S-100 VI7* (pin 11) < o (J7) o < 8087 Interrupt Output 

S-100 VI6* (pin 10) < o (J6) o < S-100 INT* (pin 73) 

S-100 VI5* (pin 9) < o (J5) o < 80130 Interrupt Output 

S-100 VI4* (pin 8) < o (J4) o < 80130 "Delay" Output 

S-100 VI3* (pin 7) < o (J3) o < 80130 "Baud" Output 

S-100 VI2* (pin 6) < o (J2) o < 80130 "Systick" Output 

S-100 VII* (pin 5) < o (Jl) o < S-100 INT* (pin 73) 

S-100 VI0* (pin 4) < o (JO) o < 8087 Interrupt Output 



These jumpers have been arranged to provide the "most standard" 
interrupt configurations by the use of shorting plugs. The 8087 
interrupt output is positioned so that it may be easily hooked up 
as the lowest (VI7*) or the highest (VI0*) vectored interrupt 
priority by installing a shorting plug at jumper locations J7 or JO 
respectively. If no interrupt controller is to be used (not 
recommended), the 8087 interrupt output may be hooked directly to 
the S-100 master interrupt line INT* by installing a shorting plug 
between the right-hand sides of J7 and J6, or Jl and JO. If a 
vectored interrupt other than VI7* or VI0* is desired, select it by 
hooking wire-wrap wire from the right-hand side of either J7 or JO 
to the left-hand side of any of jumpers J6-1. 

The master interrupt output from the 80130 would normally be hooked 
to the S-100 master interrupt line INT* by installing a shorting 
plug between the right-hand side of jumpers J5 and J6. 

The timer outputs from the 80130 (Delay, Baud and Systick) are 
arranged to be jumpered to vectored interrupt lines VI4* through 
VI2* respectively by the use of shorting plugs. If other 
arrangements are desired, they may be "scramble-wired" with the use 
of wire-wrap wire. Hook the right-hand side of the timer output 
jumper to the desired VI* line available at the left-hand side of 
the jumpers. 

The standard CompuPro system configuration requires no jumpers on 
JO through J7. 

Jumper J8 is located near the top left-hand corner of the board. A 
shorting plug should be installed at this location if there is no 
8087 on the board. The shorting plug should be removed if an 8087 
is installed. 



****** INSTALLING AN 8087 MATH CO-PROCESSOR ****** 

The CPU 86/87 is designed to accept an 8087 math co-processor 
chip made by Intel. Currently, the fastest 8087 available runs 
at 5 MHz. This means that the 8086 must also run at 5 MHz. CPU 
86/87 boards are shipped from CompuPro running at either 8 or 10 
Mhz depending on the version you ordered. If you ordered the CPU 
86/87 from CompuPro with an 8087 installed, we shipped your board 



running at 5 Mhz, and we verified that the 8087 was operational. 
If you ordered the CPU 86/87 without the 8087 chip, but now would 
like it installed, you may return the board to CompuPro for an 
upgrade. This is the recommended procedure, as it ensures that 
the hardware will be working correctly. If you want to install 
your own 8087, be aware that you will have to unsolder some 
components and solder in some new ones. If you do this badly, it 
will void your warranty. Also, even if you do the job neatly, 
but it doesn't work when you're finished, we are going to charge 
you to find the problem. Don't expect help over the phone, 
either. 

For the brave among you, here is the procedure: Carefully 
unsolder capacitors C9 and CIO, crystal XI and inductor LI. 
Replace crystal XI with a 15 MHz crystal. Replace capacitor C9 
with a 220 pfd silver mica capacitor. Replace capacitor CIO with 
a 120 pfd silver mica capacitor. Replace inductor LI with a 1 uH 
inductor. Carefully plug the math chip into socket U19. Remove 
jumper J8. Hope that it works. 

Again, we strongly suggest that you return the CPU 86/87 to the 
factory for an 8087 upgrade. 

******************************* 



USING THE MEMORY MANAGER 

The memory manager on the CPU 86/87 is a simple 4 bit parallel port 
that allows control of the upper four extended address lines (A23- 
20) on the S-100 Bus. 

The data appearing in the upper four data bits of an I/O write to 
the memory manager's port address will be present on the address 
lines at the next CPU cycle. The lower four data bits will be 
ignored. 

The use of the port seems deceptively simple. In fact, there are 
several things to watch out for. The first is that the page 
running the code that bumps the memory manager will vanish as soon 
as the write occurs. This means that the new page must contain 
known code so that the 8086 can continue. How do you get it there? 
It's like the chicken and the egg. The CPU cannot put the code 
there itself. However, you can use the DISK1 to read a sector (or 
more) there directly, since it can transfer to the full 24 bit 
range. Or the MPX-1 can be used to put or move code to the 
extended page. The standard MPX-1 ROM code has a function to move 
data between extended pages. 

Secondly, since the 8086 is pipe-lined machine, the actual write to 
the memory manager port may occur after the next several 
instructions are fetched. This can cause problems if the 8 or so 
bytes following the output instruction are not identical in both 
pages. Make sure they are! 



BRIEF SUMMARY OF RUNNING 

THE 8086/80130 WITH VECTORED INTERRUPTS 

1) Decide who is going to control your interrupts. You have 
the option of using the 80130 in the 8086 board or the 8259s 
in the System Support board. Whenever both boards are 
present, the unused controller(s) must be put in a benign 
state (all 8 or 16 interrupts masked) since the interrupt 
chips come up in undefined states - most likely ready to 
interrupt in some obscure manner. 

If you use the System Support board as your interrupt 
controller it may be easiest to just remove the 80130 chip 
from the 8086 board. In this case, do not jumper J0-J7 
since the interrupt line drivers (U44) with open inputs will 
have active inverted outputs that will activate the 
interrupt lines. 

Using the timers and/or baud rate generator of the 80130 
chip to drive the System Support interrupts requires 
programming the 80130's interrupt controller into a dormant 
state. Here the 8086 board I/O select switch (Switch 3 
paddle 2) must be on for software access to the 80130. In 
jumpering J0-J7 be careful not to jumper to the 80130's 
interrupt output (right side of J5). 

Although the following is for using 80130 to control 
interrupts, it is for the most part applicable to the 8259s. 

2) There are two physical considerations - turn Switch 3 paddle 
2 on - again this allows you to select the 80130. Also 
jumper the right sides of J5 and J6 together. This connects 
the INT output of the 80130 to S-100 bus pin 73 (INT*) and 
thus to the INT input of the 8086. 

3) Next you have to program the 80130. Read the following 
section as it does much to clarify an inherently obtuse 
situation. The comments on the 8259 in the System Support 
manual are also useful. Note that Initialization Control 
Word 2 (ICW2) sets the base address of your vector table. 
80H gives a starting address of 200H. 

4) Operational Control Word 1 (0CW1) must be given to enable 
(unmask) as many of the 8 interrupts as you want. 00H 
enables all eight vectored interrupts. 

5) As you set up the table, remember the order of the bytes is 
low Instruction Pointer, high IP, low Code Segment, high CS. 
Don't assume what CS will be - copy it from the processor at 
run time. 
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6) After you have received an interrupt, you have to do two 
things if you ever want to get another. One thing is, you 
have to execute an enable interrupts instruction. The other 
is to send out the specific 0CW2 to acknowledge to the 80130 
that the interrupt has been handled. 



USING THE 80130 INTERRUPTS AND INTERVAL TIMERS 

The 80130 supplied with the CPU 86/87 board contains no ROM code, 
but you can still use the interrupt controller and interval timers 
built into the part. The CP/M-86 software supplied by CompuPro for 
the CPU 86/87 contains special code to initialize the interrupt 
controller to a benign state (all interrupts masked). This 
section of the manual assumes that you are familiar with interrupts 
and interval timers. If not, we refer you to the Intel Data 
Catalog - read the sections on the 8259A and the 8253/54. Also, 
the 8086 Family Handbook has an exceptional application note on the 
8259A and interrupts in general (it's AP-59). If you happen to 
have a CompuPro System Support Manual, much of the data and 
concepts are covered there as well. This section is only intended 
to give you the raw data about the internals of the 80130, and is 
not a tutorial. The following is not a complete description, but 
is intended to be as guidelines. 



INTERRUPT CONTROLLER INTERNALS 

As mentioned above, this section is not going to attempt to explain 
how interrupts work. The interrupt section of the 80130 is very 
similar to the 8259A when operating in the 8086 mode. The 80130 
accepts two types of command words to set Its various operational 
modes. Between three and six of these words must be sent to the 
chip before it may be used. These are called "Initialization 
Command Words" or abbreviated ICWs. Once the initial ICW sequence 
is sent, it need not be sent again. After the ICW sequence, two 
"Operational Command Words" (OCWs) must be sent to complete the 
initial programming sequence. OCWs are used during normal 
interrupt operation for things such as interrupt masking, end-of- 
interrupt and reading the interrupt status. OCWs may be sent any 
time after the ICWs are sent. 

NOTE: The following examples assume that the 80130 is addressed at 
I/O port locations FFF0 through FFFF hex. 



Interrupt Initialization 

Whenever a command is written to address FFF0H with D4=l, the data 
is interpreted by the 80130 as Initialization Command Word 1 
(ICW1). ICWl starts an internal initialization sequence during 
which the following events automatically occur: 
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a) The edge sense circuits are reset, which means that 
following the initialization sequence, an interrupt request 
(IR) input must make a low-to-high transition (high-to-low 
on the S-100 Bus) to generate an interrupt, until the IR 
input is programmed as level sensitive input (which it must 
be to meet the S-100 vectored interrupt specs). 

b) The interrupt mask register is cleared, meaning that all IR 
inputs are enabled. 

c) Status read is set to allow reading of the Interrupt Request 
Register (IRR). 

d) The Interrupt Acknowledge circuitry is reset and prepared 
for the first INTA cycle. 



ICWs 1 and 2 

Issuing ICW1, ICW2 and ICW4 is the minimum amount of programming 
needed by the 80130 priority interrupt controller (PIC). ICW1 
contains bits that indicate whether the 80130 can expect to see 
ICW3, ICW5 and ICW6 sent or not. Once ICW1 has been written, the 
following writes to I/O address FFF2H must be the sequence of ICW2, 
ICW3, ICW4, ICW5 and ICW6 (unless ICW3, ICW5 and ICW6 are not 
needed, as specified in ICW1). The 80130 is ready to accept inter- 
rupts after the last ICW is sent. Note that ICW3, ICW5 and ICW6 
are never sent in the implementation of the 80130 on the CPU 86/87. 

ICW2 contains the bits T7-3 of the vector supplied to the 8086 
during the second INTA cycle. The remaining bits (T2-0) are deter- 
mined by the interrupt level being acknowledged and are supplied 
automatically by the 80130. 



ICW1: 

ICW1 is specified by writing to I/O port address FFF0H with D4 set 
to "1". The meaning of the bits of ICW1 are as follows: 

Bits 7 and 6: Unused and may be any value. 

Bit 5: Should always be set to "0". This tells the 80130 
not to expect ICW6. 

Bit 4: Should always be "1". Indentifies ICW1. 

Bits 3 and 2: These bits should always be sent with bit 3 = 
"1" and bit 2 = "0". This tells the 80130 that all the IR 
inputs are level sensitive (to be compatible with the S-100 
bus spec), and not to expect ICW5. 



12 



Bit 1: Should always be set to "1". This tells the 80130 
that there are no other slave interrupt controllers on the 
board. 

Bit 0: Should always be "1". 

These really don't leave you leave you much choice as to what value 
to send for ICW1, does it? The value to send is: 1BH. 



ICH2: 

ICW2 is specified by writing to I/O port address FFF2H immediately 
after writing ICW1 above. The meaning of the bits in ICW2 are as 
follows : 

Bits 7 through 3: These bits specify the five most signifi- 
cant bits of the vector byte supplied by the 80130 to the CPU 
during an INTA cycle. Bit 7 is the most significant and Bit 3 
is the least significant. These are equivalent to bits T7-3 
as referred to in the 8259A and 8086 documentation. 

In brief, here is how the bits specify an address: 

The 8086 responds to interrupts by sending out two INTA cycles. The 
first is a "dummy" cycle, but one byte of vector information is 
read by the 8086 during the second INTA cycle. Bits T7-3 are sent 
during this time on D7-3. T2-0 (D2-0) are dependent upon the IR 
level being acknowledged, which the 80130 supplies. 

The 8086 takes this byte and multiplies it by 4 (shifts left twice) 
giving a 10 bit "vector" with the two least significant bits = "0". 
This vector is used to point to a memory location, with all higher 
address bits = "0". Since the lower two bits are "0", this address 
will point to any one of 256 four byte, blocks starting at physical 
address 0. The 8086 picks up IP and CS bytes from these four 
locations and branches to the interrupt service routine. 

Hence, T7-T3 may be thought of as corresponding to address bits A9- 
5. Address bits A4-2 are supplied by the 80130 and Al and A0 
always = "0". 

Bits 2 through 0: Unused and may be any value. 



ICW3: 

ICW3 is not used in the CPU 86/87 configuration for the 80130. 

ICW4: 

ICW4 is always required by the 80130 and is used to select between 
the Special Fully Nested and Fully Nested modes. For a complete 
description of what these modes are, see the 8259A literature 
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referenced above. The 80130 as implemented on the CPU 86/87 will 
normally use the fully nested mode. 

ICW4 is written to I/O address FFF2H immediately following ICW2 
above. The meaning of the various bits of ICW4 are as follows: 

Bits 7 through 5: Unused, but should be set to "0". 

Bit 4: Used to select between the Special Fully Nested Mode 
and the Fully Nested Mode. When set to "1", selects the 
Special Fully Nested Mode. When set to "0", selects the 
Fully Nested Mode. Normal operation of the 80130 on the CPU 
86/87 requires the Fully Nested Mode, so set this bit to 
"0". 

Bit 3: Should always be set to "1". (Selects the buffered 
mode, but is actually ignored by the 80130.) 

Bit 2: Should always be set to "1". (Selects the 80130 as 
the master, but is actually ignored by the 80130.) 

Bit 1: Should always be set to "0". (Selects the normal end 
of interrupt mode, but is actually ignored by the 80130.) 

Bit 0: Should always be set to "1". (Selects the 8086 
mode, but is actually ignored by the 80130.) 

Note: The above bits that are "ignored" by the 80130 are "hard- 
wired" internally to select the modes as described above. However, 
they should always be written as described. 



ICW5 and ICW6 

ICW5 and ICW6 are not used in the CPU 86/87 configuration of the 
80130. 

OCW1 

0CW1 is used to set and clear the interrupt mask bits in the 
Interrupt Mask Register. When a bit is set to "1", it masks or 
inhibits its respective IR input. When a bit is set to "0", that 
IR input is unmasked or enabled. 

0CW2 is written to I/O address FFF2H any time after the ICWs are 
sent. The mask bit to IR input correlation is as follows: 



Bit 


7 


it i it 
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IR7, 


"0" 


enables 


IR7 


Bit 


6 


it i it 
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5 
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IR2, 
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Bit 


1 


ii -I ti 
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IRl, 
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IRl 


Bit 





mi ii 
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IR0, 


IIQII 


enables 


IRQ 
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Masking an IR channel does not affect other channels in operation. 
0CW2 

Use 0CW2 to issue end of interrupt (EOI) commands to the 80130. 
The 80130 operates only in the specific EOI mode, which means that 
each interrupt's service routine must send an EOI command to the 
80130 when that routine is completed. The EOI sent must be the 
specific EOI for that interrupt level. 

0CW2 is written to I/O address FFF0H any time after the ICWs are 
sent. The meaning of the bits in 0CW2 are as follows: 

Bits 7 through 5: Should always be sent with bit 7 = "0", 
bit 6 = "1" and bit 5 = "1". This selects the specific EOI 
mode. The 80130 actually ignores these bits, but they should 
be sent as described anyway. 

Bits 4 and 3: Both bits should always be set to "0". This 
selects 0CW2. 

Bits 2 through 0: These bits contain a binary code that 
indicates which IR level gets the EOI as shown in the table 
below: 

Bit 2 Bit 1 Bit IR level that gets EOI 

IRO 
IR1 
IR2 
IR3 
IR4 
IR5 
IR6 
IR7 

Note: One point that causes a lot of confusion for people writing 
interrupt service routines is the need for sending an EOI. Without 
the EOI, that IR level and all those of a lower priority will never 
be interrupted again. 



OCW3 

0CW3 is used to read two of the registers internal to the 80130. 
Those registers are the Interrupt Request Register (IRR) and the 
In-Service Register (ISR). 

The IRR contains 8 bits which correspond to the IR inputs that have 
not yet been serviced. It is essentially an image of the IR inputs 
with bit 7 corresponding to IR7 and bit corresponding to IRO. 
The bits in the register are "1" when an interrupt is pending. 
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The ISR register contains information as to which interrupt is 
being serviced. Bit 7 corresponds to IR7 and bit corresponds to 
IRO. A bit is "1" if that level is "in-service". 

Reading the IRR or ISR is performed by sending an OCW3 that selects 
one of the two registers for reading. Any I/O reads following 0CW3 
made to I/O address FFFOH will then yield the appropriate 
register's data. Note that the 80130 "remembers" the last register 
requested, so subsequent reads of the same register do not require 
0CW3 to be sent again. 

0CW3 is sent by writing to I/O address FFFOH. The meaning of the 
bits of 0CW3 is shown below: 

Bits 7 through 5: Unused. Can be any value. 

Bits 4 and 3: Bit 4 should always be sent as "0" and bit 3 
should always be sent as "1". This selects 0CW3. 

Bits 2 and 1: Unused. Can be any value. 

Bit 0: Used to select between the IRR and ISR. When set to 
"0" selects the IRR for reading. When set to "1", selects 
the ISR for reading. 



Reading Interrupt Mask Register 

The interrupt mask register may be read at any time by performing 
an 1/0 read to address FFF2H. 

80130 Interrupt Inputs 

The 80130 interrupt inputs are hard-wired to the S-100 bus vectored 
interrupt lines as shown below: 

S-100 VI7* > > 80130 IR7 

S-100 VI6* > > 80130 IR6 

S-100 VI5* > > 80130 IR5 

S-100 VI4* > > 80130 IR4 

S-100 VI3* > > 80130 IR3 

S-100 VI2* > > 80130 IR2 

S-100 VII* > > 80130 IR1 

S-100 VI0* > > 80130 IRO 



80130 Interrupt Outputs 

For a complete discussion of the 80130 interrupt outputs, see the 
section of this manual entitled "Jumpers" in the "Switch Settings 
and Option Selection" section. 

That completes the description of the 80130 interrupt controller. 
The next section describes the internals of the interval timer 
section of the 80130. 
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COUNTER TIMER INTERNALS 

The interval timer section of the 80130 is basically a "hard-wired" 
8254 (which is very similar to the 8253). This section is not 
intended to tell you everything there is to know about these parts 
or interval timers in general, but will just tell you about the 
80130 implementation of them. For more information, refer to the 
8254 and 8253 data sheets in the Intel Component catalog. The 8253 
data sheet is also reprinted in the System Support 1 manual, if you 
happen to have a copy. 



Description of Timer Modes 

Timer - is hard-wired to the Rate Generator mode (Mode 2). 
Upon loading the last byte of Timer 0's count register (CR), 
the timer will start counting down. When it reaches zero, the 
SYSTICK output will go low for one clock cycle. The CR will 
automatically be reloaded and counting will start again. 

Timer 1 - Timer 1 is hard-wired to the Interrupt on Terminal 
Count mode (Mode 0). The DELAY output will be set low upon 
initialization and will remain low until the CR is loaded. 
The timer will then start counting down, and when it reaches 
zero the DELAY output will go high and will remain high until 
the CR is reloaded. 

Timer 2 - is hard-wired to the Square Wave Generator mode (Mode 
3). After the CR is loaded the BAUD output will contain a 
square wave at a frequency dependent on the count value. The 
output will be low for half the value and high for the other 
half. 



Sending Data to Timers 

Loading the CR of each timer consists of the following sequence: 

1) Write the timer initialization byte to the timer control 
port (FFFEH). 

2) Write the LSB of the count value to the appropriate timer 
data port. 

3) Write the MSB of the count value to the timer data port. 
Counting then starts. 

There are three timer initialization bytes, one for each timer. 
The timer initialization byte is always written to I/O address 
FFFEH (the timer control port). The three timer initialization 
bytes are as follows: 
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Timer = 00111010 
Timer 1 = 01110000 
Timer 2 = 10110110 

The count values are sent to each timer's data port. The LSB is 
always sent first, followed by the MSB. It is not possible to 
write the count value in a single 16 bit operation. The timer's 
data port I/O addresses are as follows: 

Timer = FFF8H 
Timer 1 = FFFAH 
Timer 2 = FFFCH 



Reading Count Value 

To read the current value of any of the count registers, it is 
necessary to send the timer a special "latch count" command. This 
does not stop the timer from counting, but stores the current count 
value in a latch so that the CPU doesn't read the counter data just 
as it's changing (which could result in erroneous data). 

Each timer has its own "latch count" command byte that is sent to 
the timer control port (FFFEH). The commands are: 

Latch Count Command for Timer = 00000000 
Latch Count Command for Timer 1 = 01000000 
Latch Count Command for Timer 2 = 10000000 

After the latch count command is sent to the timer control port, 
the latched data may be read from the appropriate timer's data port 
(see above for addresses). The LSB is always read first, followed 
by the MSB. After both bytes are read, the latch holding the data 
will be unlatched and begin tracking the count registers again. 
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THEORY OF OPERATION 

This section of the manual will explain, in general, how the 
circuitry on the CPU 86/87 works. In the following discussion, it 
will be helpful to refer to the schematic diagrams contained in the 
appendix of this manual. 

The CPU 86/87 is based on the Intel 8086 CPU. The clock for the 
CPU is generated by the 8284A clock generator IC (U40). It uses an 
external oscillator consisting of two inverters, crystal XI, 
capacitor C9 and inductor LI. The crystal is a third overtone 
type, and is three times the desired processor frequency. For 
example, to run the CPU at 8 MHz, a 24 MHz crystal would be used. 
If the crystal value is changed, the value of C9 must also be 
changed . 

The clock output of the 8284A is sent unbuffered to the 8086, 8087 
and 80130 to keep the rise and fall times within spec. Terminating 
resistors R7 and R18 minimize undershoot and reflections. 
Inverters are used to provide the CLK* and CLK signals for the rest 
of the board. The CLK signal is buffered by a Tri-state™ buffer to 
form bus 4. The Tri-state enable is driven by the inverting 
output of flip flop U41b. The D and CLR inputs to this flip-flop 
are driven by the newly defined bus line d>DSB* on pin 21 of the S- 
100 bus. This line will be driven low by a temporary master coin- 
cident with the CDSB* signal (which is just after the rising edge 
of the clock). This will immediately cause the bus clock to be 
Tri-stated. Pull-up R17 makes sure that it floats to the high 
state, but the temporary master should be driving the clock now 
anyway. When the temporary master relinquishes the bus, it will 
drive CDSB* high and float its clock high. Flip-flop U41b will 
then be free to enable the CPU 86/87's clock , but not until after 
the next rising edge of it. This ensures that there are no slices 
on the clock line. 

The 8086 (U20) and the 8087 (U19) have most of their common pins 
wired together. The exceptions are the RQ/GT* lines. When there 
is no 8087 installed, J8 connects the RQ/GT* line to the 8086 
directly. When the 8087 is installed, J8 is removed and the RQ/GT* 
line goes through the 8087 and then to the 8086. This ensures that 
DMA requests are handled correctly if the 8087 is in control of the 
bus. 

The 8288 system controller IC (U36) is used to generate the read 
and write strobes, the ALE signal, and the direction and data 
buffer control signals DT/R* and DEN. ALE is used to latch the 
address information from the CPU into the address latches U21,32 
and 45. These also provide the buffering for the S-100 bus address 
lines. ALE is also used by U15b to generate the pSYNC signal. The 
pSTVAL* signal is a function of pSYNC and CLK*. 

The MRDC*, IORC* and INTA* signals are ANDed by a section of U38 to 
form a generalized read strobe, which eventually becomes pDBIN. 
Similarly, the MWTC* and I0WC* signals are ANDed by a section of 
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U25 to form a generalized write strobe, which eventually becomes 
pWR*. 

All these "p" signals are buffered by U37 and go out to the bus. 

The S-100 status lines are generated by a 74S288 bipolar PROM. The 
three status lines from the CPU (S0*-S2*) are latched by U51. The 
outputs of U51 go to 3 of the address inputs of the PROM. The PROM 
then decodes the proper status and puts it out on its data output 
lines 01-7. Data output 08 is used to inhibit generation of a wait 
state by flip-flop U6b. Wait states will be allowed only if the 
right cycle type is occurring (determined by the two wait state 
switches connected to the other two address inputs to the PROM). 

The S-100 status lines are buffered by U52. 

The sXTRQ* line is generated by the OR of the latched BHE* signal 
LBHE* and AO. If LBHE* and AO are low, and it's not an interrupt 
acknowledge cycle, a sixteen request will be generated. If SIXTN* 
goes low, indicating that a 16 bit transfer can occur, the output 
of U35 will go high, causing the ONECYCLE signal to be true. This 
signal tells the CPU to complete the 16 bit transfer at full speed. 
If the SIXTN* signal stays high, U35's output will be low causing 
the ONECYCLE signal to be false. This starts a process whereby the 
CPU 86/87 will halt the 8086 and read or write two bytes serially. 
This is performed by the state machine consisting of U12, U13 and 
U14, which generates the signals STBINH, FORCE, and FLIP. These 
are used to sequence the logic on the board to run the two bus 
cycles . 

The data bu3 is buffered, multiplexed and latched (depending on 
what is required) by U16, 47, 48 and 49. The control of these 
buffers and latches is performed by a 256x4 bipolar PROM (U50). 
The direction inputs of U47 and 49 (the main data bus buffers) are 
connected directly to the DT/R* line from the 8288. A section of 
U35 is used to disable the PROM entirely, which gives us a few more 
input terms. All buffers will be disabled when DODSB*, or ACK* 
(the signal specifying that an access to the 80130 is occurring) 
is true, and DEN is false. The rest of the inputs to the PROM 
control when the various buffers are enabled. The LAO, LBHE* and 
DT/R* signals control the basic 16 bit cycles, while the FLIP and 
TWOCYCLE signals control the buffers during a byte serial transfer. 
The POJ* signal disables the buffers if the power-on-jump signal is 
active. The INTAK signal routes the byte data correctly during 
interrupt acknowledge cycles. 

The 80130 interface is mostly straight-forward decoding logic, with 
U9, U10 and part of U8 providing the IOCS* signal and U7 and U8 
providing the MEMCS* signal. These are the I/O chip select and 
Memory chip select signals, respectively. The 80130 address/data 
and status lines connect to the equivalent 8086 lines similar to 
the 8087. The ACK* output signifies that an access to the 80130 is 
occurring. 
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The memory manager circuitry is merely a 4 bit I/O port whose 
address is decoded by U33 and U22. U46 is a 4 bit latch whose 
output passes through to U45 which keeps the address from appearing 
on the bus until the next ALE and also buffers it. 

The S-100 bus uses a HOLD/HLDA protocol for DMA requests, but the 
8086/87 use a RQ/GT protocol when in their max mode. U4, U5, and 
U6a provide the HOLD/HLDA to RQ/GT* conversion. When HOLD* is 
asserted, a pulse one clock cycle wide is issued on the RQGT* line. 
When a GT pulse is issued by the CPU on RQGT*, U6a will be set low, 
causing pHLDA to be asserted. When HOLD* goes away another pulse 
will be issued on RQGT* causing the processor to assume control of 
the bus again. One clock cycle after the last pulse, pHLDA goes 
false. 

Three sections of U56, crystal X2 (4 MHz) and U41a provide a 2 MHz 
clock for the S-100 CLOCK signal on pin 49. A separate oscillator 
was used so that CLOCK will always be 2 MHz independent of the CPU 
frequency. 

The power fail circuit causes a POC* to be issued upon the rising 
edge of PWRFAIL*. This insures that the system will recover just 
as if the power had come on for the first time, and prevents 
problems that might occur if the power dips for a short period 
causing PWRFAIL* to be asserted, but the power doesn't really stop. 
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PARTS LIST 



INTEGRATED CIRCUITS 


U40 


8284A-1 


CAPACITORS 






U41 


74LS74 






U1-U3 


7805 


U42 


7416 


C1-C6 


10 uF 


U4 


74LS74 
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C7 
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U5 


74LS02 
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7416 


C8 
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U6 


74LS74 
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C9 
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U7 
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Dl 
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U14 


74LS74 
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U15 


74LS74 
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74LS74 


Ql 
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U16 


74LS373 


U55 


74LS125A 






U17 
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U18 
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U19 
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RESISTORS 
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10 position 


U20 


8086 






S3 


8 position 


U21 
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R1-R4 


1.5K Ohm 


S4-S5 
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U22 
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R5 


4.7K Ohm 






U23 


74LS32 


R6 


10K Ohm 


JUMPERS 
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74LS04 


R7 
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U25 
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R8 


560 Ohm 


J0-J7 


8x2 position 


U26 
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10K Ohm 


J8 
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U27 
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2.2K Ohm 
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U35 
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U36 


8288 
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U37 


74LS367A 




5. IK Ohm 






U38 


74LS11 


SR8-SR9 


1.5K Ohm 






U39 


74LS125A 
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